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(54) Anti-counterfeit direction method 

(57) This algorithm is a method for resizing and 
resampling an image in one step. In the vertical, proc- 
ess or slow scan, direction, from the resampling ratio 
and from the image size variation, an algorithm can 
compute where, on the page, the scan lines may be 
deleted. For a numerical example, if the input Is 400 pix- 
els per unit time, resampling of four to one would yield 
one scan line every 1/100 of a unit. If, in addition, the 
image has to be reduced by 5%, then the final output 
would be one scan line every 1/95*^ of a time unit This 
algorithm accomplishes this result by using a running 
sum of en-or tenns. Simply stated, if it is known that the 
previous output scan was output at exactly the right 
time, the error is zero, but if the scan was output too 
soon or too late, there will be an error term. For each 
new scan that is now output, 1/400*^ of a time unit is 
added to the error term. Rnally, when the error tern 
rises to a predetermined threshold, then the algorithm 
knows that that is the closest approximation that can be 
made, the current scan line is output, 1/95^^ of a time 
unit is subtracted from the running sum, and the algo- 
rithm proceeds to the next scans. 
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Description 

BACKGROUND OF THE INVENTION 

5 [0001] A process and circuit for resampHng and resizing a digital image where each iteration converts each n pixels 
on a scan fine to an average pixel to resample to 1/n in the horizontal direction, and outputs one scan line for every n, 
plus or minus a small percentage, input scan lines to resample and resize the image in the vertical direction. 
[0002] It is frequently necessary to change the size of an image slightty. For example, deleting alternate pixels will 
reduce an image to one half, and duplicating pixels will double the image size. To change image size by less than a mul- 

10 tiple of two, an algorithm such as the nearest neighbor algorithm can be used to produce the necessary number of pix- 
els. 

[0003] it may also be necessary to resample image pixels. For example, if an image is scanned in on a scanner of 
higher pixel density and is to be processed or printed at a tower pixel density, conversion to a tower number of pixels 
per inch is required. 

15 [0004] However, if image pixels are deleted in either of these processes, data will be lost To minimize this, the pix- 
els can be averaged first. That is, a number of pixels can iDe replaced by one average pixeL 

[0005] The result of these operations is an image that is resampled and changed slightly in size while losing a min- 
imum of image quality. 

[0006] This process can be used in color copiers, as a first step in the prevention of counterfeiting. In its simplest 
20 form, paper cun-ency can be counterfeited by piadng it on the platen and copying it To prevent this, currency has marks 
of various sizes, shapes and colors. The image output of the scanner can be analyzed, and the copying discontinued if 
a cun-ency mark of a particular size is found by a cun'ency detection circuit in the copier. To defeat this detection, a 
counteffeiter may set the scanner to magnify the image size enough so that the marks will not be recognized by the cur- 
rency detector, and then reduce the image by the same amount when printing. 
25 [0007] To prevent this, the detection circuit must be supplied with a number corresponding to the amount of magni- 
fication (or reduction) that the scanner was set to, and must reduce (increase) the image size tiy the same amount 
before testing for currency marks. 

[0008] Additionally, the pixel density of the image is greater than that needed Isy the detection circuit, so the data is 
resampled first With the addition of the averaging of the image pixels, the total process becomes averaging, sizing and 
30 resampling. 

[0009] The final problem is that of circuit speed. When an original of any kind is placed on the platen, the copier can 
not start to print until the test for currency is complete, and since this test must be done for every original, the elapsed 
time must be as short as possible. There is therefore a need for an algorithm that can implemented in a pipe-lined circuit 
so that the elapsed time is minimized 
35 [001 0] In this discussion, as an aid in understanding a numerfcal example will be used where the resampling will be 
assumed to be 4 to 1 , and the resizing will be assumed to be between plus or minus 20%. 

[001 1 ] A typical color copier makes smalt changes in image size by stowing down the speed of the paper in the ver- 
tical, or slow scan direction, but in the test scan direction the clock remains unchanged, and therefore the copier can 
only change the image size slightly by using a nearest neighbor algorithm to change the density of pixels in the horizon- 

40 tal, or fast scan, direction. 

[001 2] Therefore, in the horizontal direction, all that is required is resampling the pixels before the image is resized, 
and that is accompfished by averaging four pixels at a time, and using the result as the sampled pixeL 
[0013] However, in the vertbal direction, an image change of up to plus or minus 20% will also have to be made by 
using a reduction factor of between 3 and 5 to 1 , this reduction being made by deleting the proper number of intervening 

45 scan lines. 

[0014] A circuit for accomplishing all of this in a small amount of time is needed 
SUMMARY OF THE INVENTION 

50 [001 5] This algorithm is designed to be implemented in a pipe-lined circuit which can average four consecutive pix- 
els to produce one cun-ent averaged pixel (resampling in the horizontal direction) and at the same time determine if the 
pixels on the current scan line should t3e deleted or output (resampling and resizing in the vertical direction). 
[0016] In the vertical direction, from the resampling ratio (4 to 1) and from the image size variation (+ or - 20%) an 
algorithm can compute where, on the page, the scan lines should be. For a numerical example, if the input is 400 spots 

55 per unit of time, resampling would yield one scan line every 1/1 00 of a unit If, in addition, the Image has to be reduced 
by 5%, then the final output would be one scan line every 1/95th of a time unit An algorithm could be constructed so 
that at each time when there should be a scan tine, the nearest actual scan line will be output This would produce the 
proper scan line output, but the process would be cumbersome. 
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[0017] This algorithm acx^omplishes the same result by using a running sum of en-or terms. Simply stated, if it is 
known that the previous output scan was output at exactly at the right time, the error is zero, but if the scan was output 
too soon or too late, there will be an en-or term. For each new scan that is not output, 1/400 of a time unit is added to 
the error term. Finally, when the error term rises to a predetermined threshold, then the algorithm knows that that is the 
5 closest approximation that can be made, the current scan line is output, 1/95 of a tinne unit is subtracted from the run- 
ning sum, and the algorithm proceeds to the next scans. 

[0018] The circuit uses a first section for four clock cycles to average the first four input pixels of the current scan, 
and a second section to do the resampling and resizing on the fifth dock cycle while the first section is starting on the 
four pixels of the next scan. Thus, the entire pipe-lined circuit operates the speed of the averaging section. 

10 

BRIEF DESCRIPTION OF THE DRAWINGS 
[0019] 

15 Rg 1 1s a flow chart of the algorithm. 

Rg 2 is a simplified schematic diagram of the circuit. 

DETAILED DESCRIPTION OF THE INVENTION 

20 [0020] The process proceeds by producing one average pixel for each group of four in each entire scan before 
going on the next scan. As each pixel is produced, it is either output or not as shown in Tables 1 and 2, which accpm- 
pfish resampling and resizing. For these examples, the resampling rate in both cases is assumed to be 25%. so that the 
basic process results in three of every four scan lines being eliminated. This is shown for the first four "scanlines", y = 
0 through y = 3, where the first three scanlines are not ■output" and the fourth one is output 

25 



Table 1 
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40 



45 



scanlines 


err_y = 0 


Counter Count_y = 0 


ndode 


output 


y = 0 


20 


1 


1 




y=i 


40 


2 


1 




y = 2 


60 


3 


1 




y = 3 


80 


4-^0 


2 


output 


y = 4 


-20 


0 


0 


skip 


y = 5 


0 


1 


1 




y = 6 


20 


2 


1 




y = 7 


40 


3 


1 




y = 8 


60 


4-^0 


2 


output 


y = 9 


80 


1 


1 




y = 10 


-20 


1 


0 


skip 


y=11 


0 


2 


1 




y= 12 


20 


3 


1 




y= 13 


40 


4->0 


2 


output 


y=14 


60 


1 


1 




y ^ 15 


80 


2 


1 




y = 16 


-20 


2 


0 


skip 
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Table 2 
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scanlines 


err_y = 0 


Count_y = 0 


mode 


output 


y = 0 


-20 


1 


1 




y = 1 


-40 


2 


1 




y = 2 


-60 


3 


1 




y = 3 


0 


5^1 


5 


output 


y = 4 


-20 


2 


1 




y = 5 


-40 


3 


1 




y = 6 


-60 


4->0 


2 


output 


y = 7 


0 


2 


3 




y = 8 


-20 


3 


1 




y = 9 


^0 


4-^0 


2 


output 


y= 10 


-60 


1 


1 




y=:11 


0 


3 


3 




y = 12 


-20 


4 ->0 


2 


output 


y= 13 


-40 


1 


1 




y= 14 


-60 


2 


1 




y= 15 


0 


4--^0 


4 


output 


y= 16 


-20 


1 


1 





30 

[0021] However, Table 1 also assumes that the magnification rate at the scanner was 120 %, so that the resizing 
step Witt eHmlnate sftghtly more that 25 % of the flnes. This is shown by the fact that, there is only one output (y = 8) for 
the next 5 scan lines (y = 4 to y = 8). Similarly, Table 2 assumes that the scanner magnification was 80%, and so there 
are times when there is an output every three tines. 

35 [0022] In both tables, the 'count - y = 0" column indicates the count of a line counter that is incremented or reset for 
each scan line, and the "mode" column Indicates how the current line will be handled. In mode 0 there is no output and 
the line count is not incremented, in mode 1 the line count is incremented and there is no output, in mode 2 the fine 
count is zeroed and the current line is output, in mode 3 the fine count is incremented twice with no output, in mode 4 
the line count is set to 0 and there is an output, and in mode 5 the line count Is set to 1 and there is an output. This set 

40 of results is generated by the following program. 

Variable Sub-Sampling Rate for Image Scaling Algorithm 

[0023] In the slow scan direction, instead of output one scan line for every four scan line (sub-sampling from 400 
45 spi to 100 spi), output the scan line if the variable mode is >=4 or ==2). 
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Calculation of the variable mode for each scan fine. 

[0024] 

Define scale = MAG (magnification setting if MAG = 120, scale = 120); 
half_scale = scale / 2; 

two^scale = scale *2; 
err_y = 0; 

for (y=0. county - 0; y < scanlines; Y++) 
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if (err_y > half_scale) { 
niode=0; 
err^ - = ICQ; 

} ' 

else if (eiT_y > = -half_scale) { 
err^y + = scale - 100; 
^ country ++; 

if (county =4) { 
^ country = 0; 

mode=2; 



so 
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else mode = 1; 



else { 
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20 



25 



30 



err__y + =two_scaIe - ICQ; 
country + =2; 
if (country >^) { 

mode = county ; 

country -=4; 

} 

else mode = 3; 



} 



} 

35 

[0025] To compare this program to Table 1 , the initial conditions are: 

40 scale = 120. 

half^scale = 60. 

two_scale is 240 for table 1 

en-.y, y and fine count are initialized to 0 

45 Then, for each loop 

If the error temri, err_y, is greater than 60 (that would be 80), the mode is 0, 100 is subtracted from the cun'ent 
eiT_y (80) to equal -20, and the count Is not incremented. 

If err_y is greater than -half_scale (-40 to 60), increase en-.y by 20, and increment count If the count is 4, 
mode 2, increment line count, else mode 1 Which is to reset line count to 0 and do not output a line. 

so 

[0026] The remainder of this program only applies to table 2 where 

scale = 80. 
hatf_scale = 40. 
55 two.scaleis 160 

err_y (-60) is increased by two.scale (1 60) - 100 = 60 to result in err-y = 0, and the line count is increased by 
2. If the count at this point is 4 or 5. the mode is set to that number, and the count is reduced by 4. Otherwise, 
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the mode is 3. and there is no output 



[0027] This program is generalized in Rg 1 which is a flow chart where K con^esponds to en^^y. The program starts 
at step 21 , 22 by inrtiaftzing the fine count and err_y temi to zero. If, step 23, the error term is greater than half scale, 
5 the en-or temri is decreased by 1 00, step 24, and the Mode is set to 0. step 25 (the line count is not incremented). If that 
was not the last line, step 26, the process goes through step 27 to the next fine, step 28. 

[0028] tf, step 23, the error temn is equal or less than half scale, then step 29, if the en^or temn is greater than - half 
scale, step 30, the error term is decreased tyy 100 and increased by the scale and the count is Incremented, step 31 . If 
now, step 32, the line count = 4. step 33, the fine count is reset to 0, the mode is 2 (one fine is output), step 34, and 

w there is a return to step 28. If, step 32, the count is not 4, then step 35, the mode is 1 and there is no output 

[0029] If, step 29, the error term is less than half scale, step 36, the en^or term is decreased by 1 00 and increased 
by two scale, and the count is increased by 2 at step 37. If the count is now greater than 4, step 38, step 39. set the 
mode to the count of 4 or 5 (output a line) and subtract 4 from the count, step 40. If, step 38, the count is less than 4, 
step 41 , the mode is 3 (no output). 

15 [0030] This algorithm produces output fines that are the closest approximation to the ideal result To explain this, 
the following two examples are given to show how the error dispersion is optimized. 

(1) For a magnified image with Scale =120, the objective of the algorithm is to delete 20 lines for every 120 input 
lines to restore the input image to the original size of Scale =1 00 and also to ensure that the deleted fines are evenly 
20 distributed across the 120 input lines to maintain the integrity of the input image. 

For every Scale / (Scale -1 00) input lines, delete 1 fine. In the case of Scale = 120, for every 6 fines, delete 1 
line. The number of fines not deleted is: 



{Scale /(Scale -1 00) -1 }=1 00/(Scale -1 00). For Scale =1 20. the number of fines not deleted is 5. In other words, 
Z5 keep the first 5 fines and delete the 6**^ fine. 

Define a variable err_y, for each line, increase the variable en'_y by 

(Scale -100), and the next line is the fine to be deleted. When err_y >60, decrease err_y by 1 00 and start over 
again. 

30 The algorithm starts out with en^y = 0 as an initial condition. For each fine kept, increase err_y by (Scale -1 00) 

until err„y exceeds Scale. Delete the next fine and decrease err_y by 100 and start over again. Essentially, err_y 
is offset from {Vi Scale -100} to Vi Scale. 

For the case of Scale =120, 100/(Scale -100) =5 after 5 fines, and err_y is increased to its full range of 100. 
For the next fine, delete the 6* fine and decrease err_y by 100 and there is no left over in err_y. 

35 

. For Scale =1 15, 100/(Scale -100) =6 with a remainder of 10. After 7 fines, err_y is increased to an absolute 
range of 105. Delete the 8*^ fine and decrease err_y by 100. The value of 5 is the error diffused to the next 
round of computation. 

40 (2) For a reduced image with Scale =80, the objective of the algorithm is to duplicate 20 lines for every 80 input fines 
to restore the input image to the original size of Scale =100 and also to ensure that the duplicated lines are evenly 
distributed across the 80 input fines to maintain the integrity of the input image. 

For every Scale / (1 00 - Scale) input fines, duplfcate 1 fine. In the case of Scale =80, for every 4 fines, duplfcate 
1 fine. The number of fines not duplicated is: 

45 

{Scale /(1 00 - Scale) -1 }= (2*Scale -1 00)/(1 00 -Scale). For Scale =80, the number of fines not dupficated is 3. 
In other words, keep the first 3 lines. At the end of the 4^^ line, duplicate the 4* line. 
Define a variable en-.^, for each fine. Decrease the variable err_y by 

(Scale -100). Until err_y < (2*Scale -100), the next fine is the fine to be dupficated. Add err_y by (2* Scale -100) 
50 and start over again. 

The algorithm starts out with err_y =0 as an initial condition. For each fine, decrease err_y by (Scale -100) until 
en-^y is less than - Scale. Dupficate the next line at the end of the next fine and add err_y by (2*Scale -100) and 
start over again. Essentially the range of err_y is offset from - Scale to Scale + (2*Scale -100)]. 
55 For the case of Scale =80, (2*Scale -1 00)/(1 00 -Scale)=3 after 3 lines, and err_y is decreased the full range of 

60. For the next fine, dupficate the 4*^ fine and increase en-_y by 60 and there is no left over in err_y. 

For Scale =85, (2*Scale -100)/(100 -Scale) = 4 with a remainder of 10. After 5 lines, en'_y is decreased to a 
range of -75. At the end of B*** fine duplicate the 6*** line and Increase err_y by 70. 
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The value of -5 is the error diffused to the next round of computation. 

[0031] The circuit for accontpfishing the averaging, subsampfing and resizing is the two-stage pipe-lined circuit of 
Rg 2. The pixels are input at line 50. The first of the four input pixels of each t>lock bypasses the adder 52 and is appfied 

5 through the mux 51 to load the register 53. On the next three clocks, the pixels are used as one input to the adder 52 
and the register content is used to supply the running sum to the other input After the four Input pixels of the block are 
summed into a ten bit number, the sum is divided by 16 at the shifter 54, and stored through mux 55 into the fine buffer 
56. (To get an average of four pixels, one wouki normally divide by four, but here it is known that eventually four lines of 
four pixels each will finally be sunrtmed, so the division by sixteen is done here in one step). At the end of the first scan 

10 line, the line buffer has a partial sum for each pixel 

[0032] For the next scan lines the sum from shifter 54 is applied to one input of adder 58 and the other adder input 
receives the partial sum from the fine buffer transferred through mux 59 to the output register 60. If this result is yet 
another partial sum, it is loaded back into the line buffer 56 through mux 55. If this is the final averaged pixel, it Is (usu- 
ally) output through register 60. 

15 [0033] A compPication is that in mode 0 the entire scan line is ignored, and the line counter is not incremented. In 
all cases 1 6 pixels need to be averaged for each output pixel. In this Mode 0 case, there will be one output for five input 
scans, but only four will be used to supply the required total of 1 6 pixels. 

[0034] Similarly, in Table 2 there are times when there is an output every three scan lines. To get 1 6 pixels in this 
case, one set is sent to a doubler 61 and added in adder 62 to get the correct output 
20 [0035] In addition, the modulo 3 counter 64 is used in the algorithm to generate the mode numbers as shown in the 
flow chart of Fig 2, and a RAM address counter 63 is used to count down scan Hne clocks to generate an address 
pointer for RAM 56. 

[0036] This entire circuit uses four clocks to average the four input pixels, and the remainder of the circuit is pipe- 
lined so that it will execute on the first clock of the next block. 
2$ [0037] While the invention has been described with reference to a specific embodiment, it will be understood by 
those skilled in the art that various changes may be made and equivalents may be substituted for elements thereof with- 
out departing from the true spirit and scope of the invention. In addition, many modifications may be made without 
departing from the essential teachings of the invention. 



1. A method of resizing and subsampling a video image of pixels by either outputting or not outputting each scan fine 
of pixels, where the subsampling is by a tector of n, comprising the following steps: 



45 2. The method of Claim 1 wherein the enror is computed t>y, for each input scan line, adding to the en^or sum a number 
that is a function of the distance between input scan lines, and subtracting from the sum a number that is a function 
of the desired distance between output lines for each line output. 
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a) going to the next scan line and computing where the next scan fine should be output and a number that is a 
function of the error that would result if the current line were to be output, 

b) If the error is greater than a first predetermined amount, returning to a), 

c) if the error is greater than a second predetermined amount, incrementing the count, 

if the scan count is equal to n outputting the scan line, setting the scan count to zero, and returning to a); oth- 
erwise return to a), 

d) incrementing tfie scan count by 2, 

e) if the scan count is equal to or greater than n, outputting a line, decrementing the scan count by n, and 
returning to a); otherwise, retuming to a) 



so 
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FIG. 7 
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